import { store } from '/@/store/index.ts';
import { Session } from '/@/utils/storage';
import { NextLoading } from '/@/utils/loading';
import { setAddRoute, setFilterMenuAndCacheTagsViewRoutes } from '/@/router/index';
import { dynamicRoutes,roleHome } from '/@/router/route';
import { getMenuByAuth, useMenuApi } from '/@/api/menu/index';

const useMenuApis = useMenuApi();
const layouModules: any = import.meta.glob('../layout/routerView/*.{vue,tsx}');
const viewsModules: any = import.meta.glob('../views/**/*.{vue,tsx}');
/**
 * 获取目录下的 .vue、.tsx 全部文件
 * @method import.meta.glob
 * @link 参考：https://cn.vitejs.dev/guide/features.html#json
 */
export const dynamicViewsModules: Record<string, Function> = Object.assign({}, { ...layouModules }, { ...viewsModules });



/**
 * 后端控制路由：初始化方法，防止刷新时路由丢失
 * @method  NextLoading 界面 loading 动画开始执行
 * @method store.dispatch('userInfos/setUserInfos') 触发初始化用户信息
 * @method store.dispatch('requestOldRoutes/setBackEndControlRoutes') 存储接口原始路由（未处理component），根据需求选择使用
 * @method setAddRoute 添加动态路由
 * @method setFilterMenuAndCacheTagsViewRoutes 设置递归过滤有权限的路由到 vuex routesList 中（已处理成多级嵌套路由）及缓存多级嵌套数组处理后的一维数组
 */
export async function initBackEndControlRoutes() {
    // 界面 loading 动画开始执行
    if (window.nextLoading === undefined) NextLoading.start();
    // 无 token 停止执行下一步
    if (!Session.get('token')) return false;
    // 触发初始化用户信息
    store.dispatch('userInfos/setUserInfos');
    // 存储接口原始路由（未处理component），根据需求选择使用
    store.dispatch('requestOldRoutes/setBackEndControlRoutes', JSON.parse(JSON.stringify(dynamicRoutes)));
    // 获取路由菜单数据
    const res = await getBackEndControlRoutes();
    dynamicRoutes[0].children = await backEndComponent(res.data.menuTreeList);
    //dynamicRoutes[0].children = await backEndComponent(res.data.menuTreeList);
    // 添加动态路由
    await setAddRoute();
    // 设置递归过滤有权限的路由到 vuex routesList 中（已处理成多级嵌套路由）及缓存多级嵌套数组处理后的一维数组
    setFilterMenuAndCacheTagsViewRoutes();
}

/**
 * 请求后端路由菜单接口
 * @description isRequestRoutes 为 true，则开启后端控制路由
 * @returns 返回后端路由菜单数据
 */
export function getBackEndControlRoutes() {
    // 模拟 admin 与 test
    const auth = store.state.userInfos.userInfos.roles[0];
    // 管理员 admin
    if (auth === 'admin') return dynamicRoutes[0].children;
    // 其它用户 test
    else return getMenuByAuth();
}

export function getIsSystemAdmin() {
    // 模拟 admin 与 test
    const auth = store.state.userInfos.userInfos.roles[0];
    // 管理员 admin
    if (auth === 'admin') return true;
    // 其它用户 test
    else return false
}

/**
 * 重新请求后端路由菜单接口
 * @description 用于菜单管理界面刷新菜单（未进行测试）
 * @description 路径：/src/views/system/menu/roleComponent/addMenu.vue
 */
export function setBackEndControlRefreshRoutes() {
    getBackEndControlRoutes();
}

/**
 * 后端路由 roleComponent 转换
 * @param routes 后端返回的路由表数组
 * @returns 返回处理成函数后的 roleComponent
 */
export function backEndComponent(routes: any) {
    if (!routes) return;
    return routes.map((item: any) => {
        item.path = item.data.menuUrl;
        item.name = item.code;
        item.component = item.data.menuUrl;
        let menuTarget = item.data.menuTarget
        item.meta = {
            title: item.text,
            isLink: '',
            isHide: !item.data.isMenu,
            isKeepAlive: true,
            isAffix: false,
            isIframe: false,
            roles: ['admin', 'common1'],
            icon: item.data.menuIcon,
        }
        if (menuTarget == '3') {
            item.meta.isIframe = true
            item.component = "/layout/routerView/iframes"
            item.meta.isLink = item.path
            item.path = '/iframes/' + item.code
        } else if (menuTarget == '2') {
            item.component = "/layout/routerView/link"
            item.meta.isLink = item.path
            item.path = "/link/" + item.code
        }
        if (item.text == '首页概览') {
            item.meta.isAffix = true
        }
        if (item.component) item.component = dynamicImport(dynamicViewsModules, item.component as string);
        item.children && backEndComponent(item.children);
        return item;
    });
}

/**
 * 后端路由 roleComponent 转换函数
 * @param dynamicViewsModules 获取目录下的 .vue、.tsx 全部文件
 * @param component 当前要处理项 roleComponent
 * @returns 返回处理成函数后的 roleComponent
 */
export function dynamicImport(dynamicViewsModules: Record<string, Function>, component: string) {

    const keys = Object.keys(dynamicViewsModules);
    const matchKeys = keys.filter((key) => {
        const k = key.replace(/..\/views|../, '');
        return k.startsWith(`${component}`) || k.startsWith(`/${component}`);
    });
    if (matchKeys?.length === 1) {
        const matchKey = matchKeys[0];
        return dynamicViewsModules[matchKey];
    }
    if (matchKeys?.length > 1) {
        return false;
    }
}
